aboutsummaryrefslogtreecommitdiffstats
path: root/src/pages/projets/[slug].tsx
diff options
context:
space:
mode:
authorArmand Philippot <git@armandphilippot.com>2023-12-06 18:20:54 +0100
committerArmand Philippot <git@armandphilippot.com>2023-12-07 19:12:11 +0100
commitb8eb008dd5927fb736e56699637f5f8549965eae (patch)
tree648274babea3d3d09ed3e0f5f1fef013f94158fb /src/pages/projets/[slug].tsx
parent802285872a2c57e7a5e130f32a2b45497d7687f1 (diff)
refactor(hooks): replace useGithubApi with useGithubRepoMeta
* use GraphQL API instead of REST (the inconvenient however is that we now need an authorization token...) * move fetcher in services * add tests * mock response using MSW
Diffstat (limited to 'src/pages/projets/[slug].tsx')
-rw-r--r--src/pages/projets/[slug].tsx35
1 files changed, 17 insertions, 18 deletions
diff --git a/src/pages/projets/[slug].tsx b/src/pages/projets/[slug].tsx
index b4bc906..cac6037 100644
--- a/src/pages/projets/[slug].tsx
+++ b/src/pages/projets/[slug].tsx
@@ -26,7 +26,7 @@ import { mdxComponents } from '../../components/mdx';
import styles from '../../styles/pages/project.module.scss';
import type { NextPageWithLayout, Project, Repos } from '../../types';
import { CONFIG } from '../../utils/config';
-import { ROUTES } from '../../utils/constants';
+import { GITHUB_PSEUDO, ROUTES } from '../../utils/constants';
import {
getSchemaJson,
getSinglePageSchema,
@@ -40,7 +40,7 @@ import {
} from '../../utils/helpers/server';
import {
useBreadcrumb,
- useGithubApi,
+ useGithubRepoMeta,
useHeadingsTree,
} from '../../utils/hooks';
@@ -115,31 +115,30 @@ const ProjectPage: NextPageWithLayout<ProjectPageProps> = ({ project }) => {
id: 'RwI3B9',
});
- const { isError, isLoading, data } = useGithubApi(
- /*
- * Repo should be defined for each project so for now it is safe for my
- * use-case. However, I should refactored it to handle cases where it is
- * not defined. The logic should be extracted in another component I think.
- *
- * TODO: fix this hardly readable argument
- */
- meta.repos ? meta.repos.github ?? '' : ''
- );
+ const {
+ isError,
+ isLoading,
+ meta: githubMeta,
+ } = useGithubRepoMeta({
+ name: repos.github?.substring(repos.github.lastIndexOf('/') + 1) ?? '',
+ owner: GITHUB_PSEUDO,
+ });
if (isError) return 'Error';
- if (isLoading || !data) return <Spinner aria-label={loadingRepoPopularity} />;
+ if (isLoading || !githubMeta)
+ return <Spinner aria-label={loadingRepoPopularity} />;
const overviewMeta: Partial<ProjectMeta> = {
- creationDate: data.created_at,
- lastUpdateDate: data.updated_at,
+ creationDate: githubMeta.createdAt,
+ lastUpdateDate: githubMeta.updatedAt,
license,
- popularity: repos?.github
+ popularity: repos.github
? {
- count: data.stargazers_count,
+ count: githubMeta.stargazerCount,
url: `https://github.com/${repos.github}/stargazers`,
}
: undefined,
- repositories: repos ? getRepos(repos) : undefined,
+ repositories: getRepos(repos),
technologies,
};